/* *
 * --ライセンスについて--
 *
 * 「本ファイルの内容は Mozilla Public License Version 1.1 (「本ライセンス」)
 * の適用を受けます。
 * 本ライセンスに従わない限り本ファイルを使用することはできません。
 * 本ライセンスのコピーは http://www.mozilla.org/MPL/ から入手できます。
 *
 * 本ライセンスに基づき配布されるソフトウェアは、「現状のまま」で配布されるものであり、
 * 明示的か黙示的かを問わず、いかなる種類の保証も行われません。
 * 本ライセンス上の権利および制限を定める具体的な文言は、本ライセンスを参照してください。
 *
 * オリジナルコードおよび初期開発者は、N_H (h.10x64@gmail.com) です。
 *
 * N_H によって作成された部分の著作権表示は次のとおりです。
 *
 * Copyright (C)N_H 2012
 *
 * このファイルの内容は、上記に代えて、
 * GNU General License version2 以降 (以下 GPL とする)、
 * GNU Lesser General Public License Version 2.1 以降 (以下 LGPL とする)、
 * の条件に従って使用することも可能です。
 * この場合、このファイルの使用には上記の条項ではなく GPL または LGPL の条項が適用されます。
 * このファイルの他者による使用を GPL または LGPL の条件によってのみ許可し、
 * MPL による使用を許可したくない対象者は、上記の条項を削除することでその意思を示し、
 * 上記条項を GPL または LGPL で義務付けられている告知およびその他の条項に置き換えてください。
 * 対象者が上記の条項を削除しない場合、
 * 受領者は MPL または GPL または LGPL ライセンスのいずれによってもこのファイルを
 * 使用することができます。」
 *
 * -- License --
 *
 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
 *
 * The contents of this file are subject to the Mozilla Public License Version
 * 1.1 (the "License"); you may not use this file except in compliance with
 * the License。You may obtain a copy of the License at
 * http://www.mozilla.org/MPL/
 *
 * Software distributed under the License is distributed on an "AS IS" basis,
 * WITHOUT WARRANTY OF ANY KIND、either express or implied。See the License
 * for the specific language governing rights and limitations under the
 * License.
 *
 * The Initial Developer of the Original Code is
 *   N_H (h.10x64@gmail.com).
 *
 * Portions created by the Initial Developer are Copyright (C)N_H 2012
 * the Initial Developer。All Rights Reserved.
 *
 * Alternatively、the contents of this file may be used under the terms of
 * either the GNU General Public License Version 2 or later (the "GPL")、or
 * the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
 * in which case the provisions of the GPL or the LGPL are applicable instead
 * of those above。If you wish to allow use of your version of this file only
 * under the terms of either the GPL or the LGPL、and not to allow others to
 * use your version of this file under the terms of the MPL、indicate your
 * decision by deleting the provisions above and replace them with the notice
 * and other provisions required by the GPL or the LGPL。If you do not delete
 * the provisions above、a recipient may use your version of this file under
 * the terms of any one of the MPL、the GPL or the LGPL.
 *
 * */
package com.magiciansforest.audio.soundrenderer;

import com.magiciansforest.audio.data.Air;
import com.magiciansforest.audio.file.hrtf.HRTF;
import com.magiciansforest.audio.soundrenderer.logic.sound.AudioRenderThread;
import java.io.File;
import java.io.FileInputStream;
import java.util.logging.FileHandler;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.sound.sampled.AudioFormat;
import javax.swing.JOptionPane;

public class Main {

    public static final AudioFormat DEFAULT_OUTPUT_FORMAT = new AudioFormat(AudioFormat.Encoding.PCM_SIGNED, 44100.0f, 16, 2, 4, 44100.0f, false);
    private static Viewer viewer;
    private static Air air;
    private static HRTF hrtf;
    private static AudioRenderThread audioRenderer;
    private static final Logger logger = Logger.getLogger(Viewer.LOGGER_NAME);
    public static final String _LOG_SETTING = "log";
    public static final String _LOG_SETTING_ENABLE = "enable";
    public static final String _LOG_SETTING_DISABLE = "disable";
    private static boolean logEnabled = true;

    public static void main(String[] args) {
        for (int i = 0; i < args.length; i++) {
            if (args[i].toLowerCase().equals("-" + _LOG_SETTING) || args[i].toLowerCase().equals("--" + _LOG_SETTING)) {
                String val = args[++i];
                if (val.toLowerCase().equals(_LOG_SETTING_ENABLE)) {
                    logger.log(Level.INFO, "Log enable");
                    logEnabled = true;
                } else if (val.toLowerCase().equals(_LOG_SETTING_DISABLE)) {
                    Logger.getLogger(Viewer.LOGGER_NAME).setLevel(Level.SEVERE);
                    Logger.getLogger("com.jme").setLevel(Level.SEVERE);
                    Logger.getLogger("com.jme3.app.Application").setLevel(Level.SEVERE);
                    System.out.println("Log disable");
                    logEnabled = false;
                }
            }
        }
        
        FileHandler logFileHandler;
        try {
            logFileHandler = new FileHandler("3DSound4MMD.log");
            logger.addHandler(logFileHandler);
        } catch (Exception e) {
            JOptionPane.showMessageDialog(null, e.getMessage());
            System.exit(-1);
        }
        logger.log(Level.FINE, "Logger initialization succeeded.");

        logger.log(Level.INFO, "Search default HRTF File(./HRTF/MIT.hrtf).");
        File hrtfFile = new File("./HRTF/MIT.hrtf");
        if (!hrtfFile.exists()) {
            JOptionPane.showMessageDialog(null, "Default HRTF File(./HRTF/MIT.hrtf) could not find.");
            logger.log(Level.SEVERE, "Default HRTF File(./HRTF/MIT.hrtf) could not find.");
            System.exit(-1);
        }
        logger.log(Level.FINE, "Found.");

        logger.log(Level.INFO, "Try to open the default HRTF File(./HRTF/MIT.hrtf).");
        try {
            hrtf = new HRTF(new FileInputStream(hrtfFile));
            logger.log(Level.FINE, "Succeeded.");

            logger.log(Level.INFO, "Create and configure Air condition.");
            air = new Air();
            logger.log(Level.FINE, "Succeeded.");
            logger.log(Level.INFO, "  Temperature : {0}[K]\n  AtmospericPressure: {1}[atm]\n  Humidity: {2}[mol%]\n  SoundSpeed: {3}[m/s]", new Object[]{air.getTemperature(), air.getAtmosphericPressure(), air.getHumidity(), air.getSoundSpeed()});
            try {
                logger.log(Level.INFO, "AudioRenderThread initialization");
                AudioRenderThread.createAudioRenderThread(hrtf, air, DEFAULT_OUTPUT_FORMAT);
                logger.log(Level.FINE, "Succeeded.");

                try {
                    logger.log(Level.INFO, "Open window.");
                    viewer = new Viewer(640, 480, logEnabled);
                    viewer.start();
                } catch (Exception e) {
                    JOptionPane.showMessageDialog(null, e.getMessage());
                    logger.log(Level.SEVERE, e.getMessage(), e);
                }

            } catch (Exception e) {
                JOptionPane.showMessageDialog(null, e.getMessage());
                logger.log(Level.SEVERE, e.getMessage(), e);
            }
        } catch (Exception e) {
            JOptionPane.showMessageDialog(null, e.getMessage());
            logger.log(Level.SEVERE, e.getMessage(), e);
        }
    }
}
